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(54) Method for visualizing locality within an address space 



(57) A method and that display certain aspects of a 
computer memory on a display screen in accordance 
with a fractal curve. In at least one emboaiment. the frac- 
tal curve is a Hilbert curve. The fractal curve display can 



be used as an aid in visualising various types of infor- 
mation about a computer memory. Certain embodi- 
ments have a display that remains static, while other 
embodiments have a cisplay that is dynamic and chang- 
es in real-time to reflect changes in memory. 
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Description 
BACKGROUND 

[0001 ] This application relates to computers and com- 
puter systems and further relates to a method and ap- 
paratus for visually displaying various aspects cf mem- 
ory. 

[0002] As computer systems become more complex, 
it is becoming more difficult for human beings to easily 
unaerstano and grasp ail the intricacies involved in any 
given computer system 

[0003] During execution, a computer system may 
move units of memory, such as pages or cache lines 
between units of hardware. As more complex caching 
systems are designed and as caching systems begin lo 
have more and more levels, it is becoming more and 
more difficult for human beings :o understand whether 
a given caching system is operating efficiently for the 
software executing on the computer system 
[0004] Software currently exists to aid a human oemg 
in visualizing certain aspects of a computer's memory, 
such as the performance impact of cacning These con- 
ventional software orograms. however, display memory 
using a line-by-line display on a display dev:ce. For ex- 
ample, in sucn a line-by-line display, a pixel representing 
information about a first unit of memory is displayed on 
a first line in a first column of a display screen. A pixel 
representing information about a second unil of memory 
is displayed on a first line in a second column of the dis- 
play screen. A pixel representing information about a 
last unn of memory may be displayed on a last line in a 
last col jmn of a display screen and so on Pixels rep- 
resenting information about intermediate units cf mem- 
ory are disolayed. one after the ether, on consecutive 
rows and in consecutive columns wttnm each row (or 
vice ve-sa .n consecutive columns and rows) 
[0005] The term "locality cf memory" relers to the lo- 
cation of data(e g . variables) within memory in time and 
space Accessing a variable closely in time is called 
"temporal locality " Accessing variables stored physical- 
ly close together is called "spatial locality." Physical lo- 
cations in a memory that are close together have a high 
spatial :ocality. For example, a variable that is reaa from 
close together in time has a high temporal locality For 
example, a £9 ,h memory unit ano a 50 th memory unit 
(such as bits, bytes, words, pages etc.) that are physi- 
cally close to each other in a computer memory have a 
high spatial locality. As another example, ff a variable is 
read twice in quick succession ;he variable has a high 
temporal locality. On modern computer systems, tem- 
poral and spatial locality impact performance 
[00061 Unfortunately in conventional iine-by-line vis- 
ualization software, even though a 49 [h memory unit is 
physically contiguous to a 50 Ih memory unit in the actual 
memory of the computer, it is entirely possible that the 
display pixels corresponding to the memory units will be 
on opposite sides of the display screen For example. 



the pixel corresponding to the 49 th memory unit might 
be the last column in iow n. wnile the pixel correspond- 
ing to :he 50 ,h memory unit might be displayed in the 
first column of row n+1 Because conventional visuali- 

5 zation tools do not necessarily show memory units hav- 
ing a high locality as being physically near each other 
cn the display, conventional visualization tools are not 
ideal for aiding a human oemg in visualizing now various 
memory units relate to each other or for visualizing lo- 

'0 cality 

[0007] Another example of conventional visualization 
software displays memory accesses by address on one 
axis of a graph and time on the other axis. This method 
also fails to present data in a way that effectively aids 
'$ human understanding of the relationships between the 
aata. 

SUMMARY OF THE INVENTION 

20 [0008] The described embodiments of the present in- 
vention provide a method and apparatus that display 
certain aspects of a computer memory on a display 
screen in accordance with a 'racial curve instead of a 
line-by-line display In at least one embodiment, the frac- 
as tal curve is a Hilbert curve The fractal curve display can 
be used as an aid in visualizing various types of infor- 
mation about a computer memory. Certain embodi- 
ments have a display that remains static, while other 
embodiments have a aisplay lhat is dynamic and chang- 

30 es in real-time to reflect changes in memory. 

[0009] For example the display can be used as an 
aid to visualize memory access patterns, such as when 
and/or where read or write operations occur in a com- 
puter memory As a second example, the display can be 
used as an aid :o visualize wnich pages are currently 
being swapped in or cut of various levels oi memory in 
a virtual memory system As a third example, the display 
can be used as an aid to visualize which cache lines are 
active in a caching system As a fourth example, the dis- 

-o play can be used as an aid to visualize which oages are 
being swapped into memory As a fifth example, the dis- 
play can be used as an aid to visualize the read/write 
permissions of various pages of memory As a sixth ex- 
ample, the display can be used as an aid to visualize 

J 5 the shared/modified exclusive states of cache lines. 
[0010] Use of a Hilbert curve as an aid in visualizing 
memory has the advantage that it allows memory 
groups equal to powers of two to be displayed near each 
other. For example, display or.s of the fractal curve cor- 

50 responding to memory addresses OOxxxxxx. where xx 
is any value, are grouped :n a same quadrant of the 
memory disoiay. Similarly, display bits cf the fractal 
curve corresponding to memory address OOOOxxxx are 
grouped within a sub-quadrant of the quadrant holding 

55 cisplay bits for the addresses OOxxxxxx. Display bits of 
the fractal curve corresponcing to memory address 
OOOOOOxx are groupea within a suo-sub-quadrant of the 
quadrant holding display bits for the addresses 
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OOCOxxxx. and so on. 

[0011] Certain embodiments use color on the display 
to indicate types of memory access, while other use dis- 
play coior to indicate a type of memory being represent- 
ed in the display, in addition, certain embodiments of the s 
present invention also use a 3-D version of a fractal 
curve, either drawn in 2D or rendered in 3D to aid :n 
visualization of various aspects of memory. In accord- 
ance with the purpose of the invention, as embodied ard 
broadly described herein the invention relates to a io 
method of displaying information, performed by a data 
processing system, comprising the steps of- receiving 
notification of a memory event, including a memory lo- 
cation: determining a portion of a fractal curve that cor- 
responds to the memory location at which tne memory '5 
event has occurred: and highlighting a portion of a dis- 
play screen in accordance with the determined portion 
of the fractal curve. 

[0012] A fuller understanding of the invention will be- 
come apparent and appreciated by referring to the fol- ?o 
Icwmg description and claims ta*en in conjunction with 
the accompanying drawings 
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[0013] The accompanying drawings whicn are -ncor- 
porated in ard constitute a part of (his specification, il- 
lustrate several embodiments of tne invention and. to- 
gether with the description, serve to explain the princi- 
ples of the invention. oo 
[0014] Fig. 1 is a block diagram of a computer system 
in accordance with one embodiment of the present in- 
vention 

[0015] Fig. 2 shows an illustration ol a curve used by 
a computer program of Fig. 1 as an aid to visualizing -?5 
certain aspects of a computer memory of Fig. 1 
[001 6] Fig. 3 is a block diagram showing an overview 
of steps performec by an embodiment of the invention 
to map ponicns of memory onto a fractal curve 
[001 7] Fig. 4 is a flow chart showing steps oerfcrmed -0 
by an embodiment of the present invention to map por- 
tions of memory onto a fractal curve 
[0018] Fig. 5 shows a state table used by tne flow 
chart of Fig. 4 to determine which portion o; the fractal 
curve corresponds to a particular portion of memory. j s 
[0019] Fig. 6 shows possible rotation values for the 
state table of Fig. 5. 

[0020] Fig. 7 shows an example of levels of quacrants 
used in the flow chart of Fig. 4. 

[0021] Figs. 8 and 9 provide an example showing how so 
to locate a portion of a displayea fractal curve corre- 
sponding to a memory address. 
[0022] Figs. 10(a) and ■ 10(b) provide examples of 
three-dimensional fractal curves shown on a two-dimen- 
sional display. 55 



DETAILED DESCRIPTION OF PREFERRED 
EMBODIMENTS 

I. General Discussion 

[0023] Fig 1 is a block diagram of a data processing 
system 100 in accordance with a preferred embodiment 
cf the present invention In Fig. 1. data orocessing sys- 
tem 1C0 includes a processor 102 and a data storage 
area(eg. amemory)l04 The example of Fig 1 shows 
that processor 102 contains an exemplary cache 111. 
although not all systems on which the present invention 
is implemented contain a cache and not all caches in 
such systems are necessarily located in processor 1 02. 
Data storage area 104 includes certain well-known 
types of data, such as data structures, pages, page ta- 
bles, etc 106. Storage area 104 also includes memory 
visualization software 110. which aids in visualization of 
various aspects of the computer system, as described 
telow in detail. Memory visualization software 1 1 0 could 
also be located in a computer system different from sys- 
tem 1 00. such as a remote system mot shown). Storage 
area 104 preferably also includes software (not shown) 
for communicating with a network, such as a LAN. WAN. 
cr the internet, although the invention also can be im- 
plemented on standalone computers, 
[0024] System 100 preferably includes an input de- 
vice 112. such as a keyboard pointing device, mouse, 
touchpad. etc.. which allows input to be read by proces- 
sor 102. System 100 preferably also includes an output 
device 140. This output device can be. for example, a 
computer monitor, a display cevice. or any device that 
allows processor 102 to send or display output. 
[0025] A person of ordinary skill in the art will under- 
stand that system 100 may also contain additional ele- 
ments, such as mout/output l:nes: input devices, such 
as a keyooard. a mouse, and a voice input device: ana 
cisplay devices such as a display terminal System 100 
may also include a computer readable input device 1 50. 
such as a floppy disk drive CD ROM reader or DVD 
reader, that reads computer instructions stored on a 
computer readable medium 160. such as a floppy disk, 
a CD ROM. or a DVDcisk. System 100 also may include 
application programs, operating systems, data etc.. 
which are not shown in the figure for the sake of clarity. 
It also will be understood that system 10 can also include 
numerous elements not shown, sucn as disk drives, 
keyboards, display devices, network connections, addi- 
tional memory, additional processors or CPUs. LANs, 
input/output lines, etc. 

[0026] In the following discussion, it will be under- 
stood f hat the steps of methods and flow charts herein 
discussed herein preferably are performed by processor 
102 (or another appropriate processor) executing in- 
structions storeo in storage area 104 (or other appropri- 
ate memorres or storage areas) It will also oe under- 
stood that the invention is not limited to any particular 
implementation or programming technique and that the 
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invention may be implemented using any appropriate 
techniques for implementing the functionality described 
herein. The invention is not limited to any particular pro- 
gramming language or operating system. 
[0027] The insiructions m storage area 104 may be 
read into storage area 104 from the ccmputcr-rcadabic 
medium 160 Execution of sequences of instructions 
contained in mam memory causes one of the proces- 
sors to perform the process steps described herein In 
alternative embodiments hard-wired circuitry may be 
used in place of or :n combination with software instruc- 
tions to implement the invention. Thus, embodiment of 
the invention are not limited to any specific combination 
of hardware circuitry and software. 
[0028] The term "computer-readable medium" as 
used herein refers to any medium that participates n 
providing instructions to a processor for execution. Such 
a medium may take many forms, ncluding out not lim- 
ited to. non-volatile media, volatile media, and transmis- 
sion media. Non-volatile media includes, for example, 
optical or magnetic disks, such as a storage device. Vol- 
atile media includes dynamic memory Transmission 
media include coaxial cables, copper wire and fiber op- 
tics, including the wires that comprise a bus within a 
computer. Transmission media can also take the form 
of acoustic or light waves, such as those generated dur- 
ing radio-wave and infra-red data communications 
[0029] Common forms of computer-readable media 
include, for example a floppy disk, a flexible disk a hard 
disk, magnetic tape, or any other magnetic medium, a 
CD-ROM. any other optical medium, punchcaros. pap- 
ertapes. any other physical medium with patterns of 
holes, a RAM. a PFOM. an EPROM. a FLASH-EPROM. 
any other memory chip or cartridge, a carrier wave, or 
any other medium from which a computer can read. 
[0030] Various forms of computer readable media 
may be involved in carrying one or more sequences of 
one or more instructions to a processor for execution 
For example, the instructions may initially be carried on 
a magnetic disk of a remote computer. The remote com- 
puter can load the instructions into its dynamic memory 
anc send the instructions over a telephone line using a 
modem A modem local to the computer system can re- 
ceive the data on the telephone line and use an infra- 
red transmitter to convert the data : .o an infra-rea signal. 
An infra-red detector coupled to a bus can receive the 
data carried in the infra-rea signal and olace the data cn 
the bus. The bus carries data to main memory, from 
which a processor retrieves and executes the <nstruc- 
tions. The instructions received by main memory may 
optionally be stored on a storage device either before 
or after execution by a processor 

II Visualization of Memory 

[0031] Fig. 2 shows a curve 200 used by a computer 
program of Fig. 1 as an aid to visualizing certain aspects 
of a computer memory of Fig. 1 in the described em- 



bodiment, the curve is not drawn explicitly Instead. 

memory addresses of. for example, storage area 104 or 

cache ill. are mapped onto tne curve. Curve 200 can. 

in fact. corresponc to any appropriate memory, whether 
5 in the computer 100 or a secondary storage" 120. The 

aisplay includes a fractal curve isuch as a Hilbcrt curve). 

where each edge of the curve represents an associated 

portion cr aspect of the memory. As explained below in 

mere cetail. use of a fractal curve to represent portions 
*o cf or aspects of a memory allows a human being to more 

easily visualize relationships between the portions of 

memory. 

[0032] Specifically, the use of a Hilbert curve allows 
each cuadrant and subquadrant of the curve to corre- 

'5 spond to respective bits of a memory address. The na- 
ture of a Hilbert curve allows easy visualization of the 
locality of memory/hardware, since addresses that re- 
, side on even powers of two map into quadrants and sub- 
cuadrants of the fractal curve. Rectangular regions of 

-0 the curve of a given size naturally correspond to hard- 
ware entities, such as cache lines or pages, so it is easy 
for a human being to see hew memory access patterns 
map onto hardware. Portions of the display that are vis- 
tally nested correspond to units of hardware that are 

25 logically nested. For example, in Fig. 2. curve 200 is 
used to aid in visualizing a ten bit address. Fig. 2 shows 
a portion 250 of curve 200 that corresponds to locations 
identified by a page (which has 256 locations). As a fur- 
ther example. Fig. 2 shows a smaller poilion 252 ol 

oo curve 200. nested within portion 250. that corresponds 
to a cache line (which has 22 locations.. 
[0033] Fig 3 is a block diagram shewing an overview 
cf steps performed by an embodiment of the invention 
to map portions ol memory onto a fractal curve. In the 

--5 cescribed embodiment, the fractal curve is not drawn 
explicitly 

[0034] The steps of c ig. 3 can be performed by mem- 
cry visualization software r0 being executed by proc- 
essor 1 02 As shown, in step 30 1 . software 1 1 0 receives 

-o rotification of a memory event at a certain address. A 
memory event can be. for example, a memory access 
such as a read or write or a cache access A memory 
event can also be the simple receipt cf a next one of 
sequential memory addresses if the software 110 is tc 

-5 map' all addresses in a memory onto the curve. In the 
cescribed embodiment, notification of a memory event 
is received from the operating system of the data 
processing system, although notification of a memory 
event can be received from any approonate source. For 

so example, the Solans operating system available from 
Sun Microsystems. Inc. allows executing programs tc 
request that the operating system notify them of certain 
memory events. (Solaris is a trademark or registerea 
trademark cf Sun Microsystems. Inc. in the Unitea 

55 States and ether countries.) As another example, other 
operating systems may allow the soltware 110 to poll 
the operating systems for the occurrence of memory 
events. 
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[0035] Sleo 302 determines a position on the fractal 
curve in accordance with the received memory address 
bits. Details of step 302 are shown in more detail in Fig. 
4. Step 304 highlights the portion of the fractal curve 
corresponcing to the received memory address. This 
portion can be a single pixel or a group of pixels, do- 
pending on the resolution of the particular implementa- 
tion of the invention. Thus, for example, if software 110 
is designee tc Highlight a portion of the curve whenever 
a read access occurs every read access of a new ad- 
dress will higniight another pixel on the curve 
[0036] Fig 4 is a flow chart showing steps performed 
by an embodiment of the present invention to generate 
a fractal curve display, where the display indicates the 
localities of memory accesses. The flow chart shows de- 
tails of step 302 and 304 of Fig. 3. Step 401 displays a 
fractal curve cn the display. As discussed above, certain 
embodiments may not perform this initial step. 
[0037] In step 402. software 110 receives notification 
of the occurrence of a memory event at a memory ad- 
dress and. n step 404. chcoses a color to reoresent the 
event. In some embodiments, all memory events are in- 
dicated by a smg'e color. In other embodiments, various 
types cf memory events are indicated by different re- 
spective colors For example, read accesses may be 
displayed in = first color, while write accesses may be 
displayed in a second color. As another example, all 
memory loca:icns having a read permission may be dis- 
played in a first color, while all memory locations having 
a read/write permission may be displayed in a second 
color. As a :hird example, all memory locations ac- 
cessed a cer:am number of times per time unit may be 
displayed in a first color, while all memory locations ac- 
cessed a different numoer of times per time unit may be 
displayed n a second color. As a fourth example, all 
memory locations filled from a cache may be displayed 
m a first color while all memory locations filled from sec- 
oncary storage may be displayed m a second color As 
a fifth examcte all memory locations in a cache that 
have been written back tc secondary storage may be 
displayed in a first color, while all memory locations that 
have not been wiuen oack may be displayed in a sec- 
ond color. 

[0038] Other variations using more than two colors 
will be apparent As a sixth example, all memory loca- 
tions having a shared, modified, cr exclusive state are 
displayed in respective colors. 

[0039] Steps 406 througn 414 form a loop that deter- 
mines which pcnion of the fractal curve corresponds lo 
the received memory address. This loop preferably is 
repeated for eacn two bits of the received address. In 
step 4C6. an initial "rotation' is set to a value of "I" as 
described beiow in connection with Fig. 6. An initial ro- 
tation of "I" is cnosen because, in the example, the 
Hilbert curve is initially oriented in this rotation. Other 
initial orientations are possible. 
[0040] Step 403 gets the next two bits of the received 
address. In step 410. software no uses the rotation and 



the two bits of the memory address to irdex into a stale 
table 1 1 4 shown in Figs 1 and 5 to yield a "next rotation" 
value and new x.y values. These x.y values are saved 
for each iteration of the loop until an x.y value has been 
5 saved for each two bits of the received address. At this 
point, in step 416. software 110 highlights a portion of 
the fractal curve, in the chosen color, at a position on 
the curve represented by the saved sequence of x ana 
y values The saved x values can be concatenated to 

io form the x position of the pcsition on the curve The 
saved y values can be concatenated to form the y posi- 
tion of the position on the curve. Further details of step 
416 are shown by the examples below 
[0041 ] Fig. 5 shows an example of the state table 1 1 4 

'5 used by the flow cnart of Fig. 4 to determine which por- 
tion of a fractal curve corresponds to a particular portion 
cf memory. The state table 11 4 in the described embod- 
iment includes input values: a current rotation value ana 
two address bits: and output values: two x.y oits and a 
next rotation value. As discussed above, each two bits 
cf a memory address along with a current rotation value 
are usea to determine output x y values and a next ro- 
tation vaiue. The sequence of x.y values are saved and 
used to highlight a portion of the fractal curve corre- 

25 sponding to the memory address. 

[0042] Fig 6 shows possible rotation values for the 
state table 114 of Fig. 5. A rotation value refers to the 
crder of two bit values in a quadrant used tc draw the 
fractal curve. For example, the "L* rotation value refers 

oo to an order 602 in which the two bit vaiues 00. 01 . 10. 
and 1 1 form a counterclockwise path, starting at a lower 
left quadrant. The "R" rotation vaiue refers to an order 
604 in wnich the two bit values 00. 01. 10. and 11 form 
a counterclockwise path starting at an upper right quad- 

35 rant. The other rotation values "U" "D". T V "u". ana 
"d" are similarly shown. 

[0043] Fig 7 shows an example of levels 702. 704. 
706 and 708 of quadrants used in the flow chart of Fig. 
a At a first level 702. the space in which :he fractal curve 

•0 is to be drawn in diviced into four quacrams Since, in 
the Figure, the rotation is ":" the quacran:s are num- 
bered clockwise from ihe too =eft as 00. 01. 10. and 11 
As further shown, each quadrant in level 1 is broken into 
four level 2 sub-quadrants, each also numbered 00. 01 . 

-5 10. and 11. the order of which deoends on the rotation 
value associated with each sub-quadrant. As further 
shown each sub-quadrant in level 2 is oroken into four 
level 3 sub-sub-quadrants, each also numbered 00. 01 . 
10. and 11. the order of which depends on the rotation 

50 value associated with each sub-sub-quadrant. As fur- 
ther shown, each sub-sub-quadrant in level 3 is broken 
into four level 4 sub-sub-sub-quadrants, each also num- 
bered 00. 01. 10 and 11 the order of which depends on 
the rotation value associated with each sub-sub-sub- 

55 Quadrant. 

[0044] Thus, in the example ot Fig. 7. each level 4 
sub-sub-sub-quadrant corresponds to one eight-bit 
memory address. Given an initial rotation and initial two 
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address bus. a slate table similar to the state table of 
Fig. 5 can be used to determine which portion of the frac- 
tal curve ne.. which suo-sub-sub quadrant) corre- 
sponds to a given memory address. Note that the mem- 
ory adcress can represent a single bit. a byte, a word, * 
a cache lino, a pace, or any other appropriate memory 
unit. 

[0045] It .vill be understood that the example of Pig. 7 
is provided by way of example and that other fractal 
curves can have other organizations and that diflerent '0 
lengths of memcry addresses will have different num- 
bers of levels of subquadrants. For example, a sixteen 
bit address where each edge of a level of the curve rep- 
resents two address bits will have eight levels. 
[0046] Figs. 6 and 9 provide an example showing how 
to locate a portion of a displayec fractal curve corre- 
sponding to a memory address In the example, soft- 
ware 110 determines a portion of a fractal curve corre- 
sponding to a memory address 10001110. Because the 
adaress has eight bits, four x.y pairs are determined ard ?o 
saved in one embodiment, a level N storage 1 30 -n ac- 
cordance witn the state table of Fig. 5. Specifically, as 
shown n Fig. 6. an initial rotation of T and initial two bit 
address values of 10 result in next rotation values of I 
U. r. and r and funher result in x.y pairs of 11 00. 10. 2$ 
and 00. 

[0047] As shown in the example of Fig. 9. the saved • 
x.y pairs identify a portion 902 of the fractal curve. Spe- 
cifically m the example, the first rotation value "I" and 
the first two address bits 1 0 identify a bottom right quad- 30 
rant in the first level. The second rotation value T and 
the second two address bits 00 identify a too left quad- 
rant in the second level The third rotation value ; Lf" and 
the third two address b:ts 1 1 identify a top ngnt quadrant 
m the third level The fourth rotation value V and the JS 
fourth x.y pair 1 0 identify a tcp left quadrant in the fourth 
level The top left auadrant ;s the curve portion 902 at 
position d0 5) wnich can be a single pixel or multiple 
pixels and which corresponds to the received memory 
adcress. ~° 
[0048] Fgs. iG'ai shows an example of a *irst level of 
a three-dimensional fractal curve Fig 10(b) shows en 
example of a two connected three-dimensional fractal 
curves. This curve can be displayed to any desired 
depth cf leveis and in either two dimensions or three ci- J 5 
mensions (given a proper display device), as is known 
by persons of ordinary skill in the art. As wnl be appre- 
ciated by persons of ordinary skill in the art. a portion of 
a three-dimensional curve corresponding tc a memory 
address can be determined using a state table similar so 
to that of F ; g. 5. 

[0049] In summary, the present invention displays 
memory locations in accordance with a fractal curve, 
such as a Hiiben curve. Use of a fractal curve tc map 
memory locations causes locations having a similar lo- 55 
cahty to be aisplayed near each other, thus imoroving 
the ability of a human being to visually appreciate the 
locality of memory events. 



[0050] While the invention has been described in con- 
junction with a specific embodiment, it is evident that 
many alternatives, modifications and variations will be 
apparent to those skilled in the art in light of the forego- 
ing description. For example, the entire display can be 
updated at encc. instead of pixel by pixel. Accordingly 
it is intended to embrace all such alternatives, modifica- 
tions and variations as fall within the spirit and scope of 
the appended claims and equivalents. 

Claims 

1 A metnod of displaying information, performed by 
a data processing system, comprising the steps of: 

receiving notification of a nremory event, in- 
cluding a memory location: 

determining a portion of a fractal curve that cor- 
responos to the memory location at which the 
memory event has occurred: 

Highlighting a portion of a disolay screen in ac- 
cordance with the determinec portion of the 
fractal curve: and 

displaying the fractal curve on the display 
screen 

3. The method of claim 1 wherein the fractal cun/e 
is a Hiibert fractal curve. 

4 The method of claim 1 wherem the memory lo- 
cation is a memory location that has eit.ner a BEAD 
permission or a READ/WRITE permission 

5 The method of claim 1 therein tne memcry 
event eaher reacs from the memory location or 
writes tc the memory location. 

6 The method of claim 1 wherein the memory lo- 
cation has been accessed at least at a predeter- 
mined frequency. 

7 The method of claim 1 wherein the memory lo- 
cation is a location in a cache memory that has been 
filled from another memory or that has been written 
back to another memory, and wherein the memcry 
location has one of a shared, modified and exclu- 
sive state. 

8. The method of claim i . wherein the fractal cur/e 
is a three-dimensional fractal curve displayed in at 
least two dimensions, wnerem a plurality of portions 
of the display screen corresponding to the fractal 
curve are highlighted at once. 
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9 T he method of claim 1 . wherein ihe display is dy- 
namic and changes as corresponding mernoiy 
events occur. 

1 0. The method of claim 1 wherein the determining s 
stop includes tnc step of determining a oortion of a 
fractal curve in accordance with a state tabie 
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